package com.entity.table;

import com.mybatisflex.core.query.QueryColumn;
import com.mybatisflex.core.table.TableDef;


/**
 * 订单商品关联信息表 表定义层。
 *
 * @author admin
 * @since 2025-05-26
 */
public class OrderProductsTableDef extends TableDef {

    private static final long serialVersionUID = 1L;

    /**
     * 订单商品关联信息表
     */
    public static final OrderProductsTableDef ORDER_PRODUCTS = new OrderProductsTableDef();

    /**
     * 关联订单 ID，表明该商品属于哪个订单
     */
    public final QueryColumn ORDER_ID = new QueryColumn(this, "order_id");

    /**
     * 商品数量，表明订单中该商品的购买数量
     */
    public final QueryColumn QUANTITY = new QueryColumn(this, "quantity");

    /**
     * 关联商品 ID，表明订单中包含的是哪个商品
     */
    public final QueryColumn PRODUCT_ID = new QueryColumn(this, "product_id");

    /**
     * 订单商品关联项唯一标识，自增主键
     */
    public final QueryColumn ORDER_PRODUCT_ID = new QueryColumn(this, "order_product_id");

    /**
     * 所有字段。
     */
    public final QueryColumn ALL_COLUMNS = new QueryColumn(this, "*");

    /**
     * 默认字段，不包含逻辑删除或者 large 等字段。
     */
    public final QueryColumn[] DEFAULT_COLUMNS = new QueryColumn[]{ORDER_PRODUCT_ID, ORDER_ID, PRODUCT_ID, QUANTITY};

    public OrderProductsTableDef() {
        super("", "order_products");
    }

    private OrderProductsTableDef(String schema, String name, String alisa) {
        super(schema, name, alisa);
    }

    public OrderProductsTableDef as(String alias) {
        String key = getNameWithSchema() + "." + alias;
        return getCache(key, k -> new OrderProductsTableDef("", "order_products", alias));
    }

}
